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We propose to consider non confluence with respect to implicit complexity. We come back to some 
well known classes of first-order functional program, for which we have a characterization of their 
intentional properties, namely the class of cons-free programs, the class of programs with an inter- 
pretation, and the class of programs with a quasi-interpretation together with a termination proof by 
the product path ordering. They all correspond to PTIME. We prove that adding non confluence to 
the rules leads to respectively PTIME, NPTIME and PSPACE. Our thesis is that the separation of the 
classes is actually a witness of the intentional properties of the initial classes of programs. 

In implicit complexity theory, one of the issues is to characterize large classes of programs, not 
extensionally but intentionally. That is, for a given class of functions, to delineate the largest set of 
programs computing this class. One of the issues with this problem is that it is hard to compare (classes 
of) programs. Indeed, strict syntactical equality is definitely too restrictive, but larger (the interesting 
ones) relations are undecidable. So, comparing theories (defining their own class of programs) is rather 
complicated. Usually, one gives a remarkable example, illustrating the power of the theory. 

We propose here an other way to compare sets of programs. The idea is to add a new feature-in 
the present settings, non determinism- to two programming languages. Intuitively, if a function can be 
computed with this new feature in a language Li but non in the language L2, we say that Li is more 
powerful than L2. Let us formalize a little bit our intuition. 

Suppose for the discussion that programs are written as rewriting systems, that is, programming 
languages are classes of rewriting systems. Let us say furthermore that a program p is simulated by 

q whenever each step of rewriting in f — )■ m G /? can be simulated by a rewriting step t' ^ u' G q. 
Equivalence of languages L\ and L2 states that any program in Li is simulated by a program in L2 and 
vice versa. 

Given a programming language L, its non deterministic extension L.n is the programming language 
obtained by adding to L an oracle choose (ri,r2) which, given two rules r\ and r2 which can be defined 
in L, applies the "righf rule depending on the context. So, given some p £ L, both pU{ri} and p U {r2} 
are supposed to be in L, but not necessarily pU{ri, r2}. 

Suppose now, that we are given two programming languages Li and L2 such that functions computed 
in Li .n are strictly included in those in L2.n. Then, L\ cannot simulate L2. Ad absurdum, suppose that Li 
can simulate L2, take / computed by p2 G L2.n but not in L\ .n. Then, each rule £ — > r in /)2 is simulated 
by a rule I' — )• r' in some program p\ S Li. But then, the derivation t\ ^- 12 ^ • ■ • ^ t^ m L2.n can be 
simulated by some derivation f { ^ f^ ^ • • • — > ?^ in L\ .n. This leads to the contradiction. 

It is clear that the notion of equivalence we took for the discussion is very strong. However, we 
believe that the argument would hold in a larger context. 

In this paper, we observe three programming languages, 

• programs with a polynomially bounded constructor preserving interpretation (F.cons) which ex- 
tend cons-free programs. 
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16 Observation of implicit complexity by non confluence 

• programs with (polynomial) strict interpretation (F.SI) and 

• programs with a quasi-interpretation together with a proof of termination by PPO, written F.QI.PPO. 

These three languages characterize Ptime. The first one is a new result, the two latter ones are 
respectively proved in [2] and f3l. 

F.cons F.SI F.QI.PPO 

Ptime = Ptime = Ptime 

Their non deterministic observation characterize Ptime, NPtime and Pspace. The second charac- 
terization has been proven in El . 

F.cons.n F.SI.w F.Ql.PPO.n 



Ptime ^ NPtime ^ Pspace 

The issue of confluence of Term Rewriting Systems has been largely studied, see for instance |fT9l . It 
benefits from some nice properties, for instance it is modular and algorithms are given to automatically 
compute the confluence up to termination. 

It is clear that there is also an intrinsic motivation for a study of non confluent programs. It would 
not be reasonable to cover all the researches dealing with this issue. But, let us make three remarks. 
First, since non-confluence can give us some freedom to write programs, it is of interest to observe what 
new functions this extra feature allows us to compute. From our result about non-confluent programs 
in F.cons.n, one may extract a compilation procedure to compute them "deterministically". Second, 
Kristiansen and Mender in ifTSl IT6l have proposed a scale -a la Grzegorczyk, using non determinism, to 
characterize LINSPACE. Finally, one should keep in mind characterizations in the logical framework. Let 
us mention for instance the characterization of PSPACE given in [7J. It is an extension of a characteriza- 
tion of Ptime, and thus, we think that their construction is a good candidate for observation as presented 
above. 

1 Preliminaries 

We suppose that the reader has familiarity with first-order rewriting. We briefly recall the context of the 
theory, essentially to fix the notations. Dershowitz and Jouannaud's survey ||6l of rewriting is a good 
entry point for beginners. 

Let ^ denote a (countable) set of variables. Given a signature £, the set of terms over £ and ^ is 
denoted by T(r, J^T) and the set of ground terms, that is terms without variables, by T(r). 

The size \t\ of a term t is defined as the number of symbols in t. For example the size of the term 
f{a,x) is 3. 

A context is a term C with a particular variable 0- If Hs a term, C[t] denotes the term C where the 
variable has been replaced by t. 

1.1 Syntax of programs 

Let "^ be a (finite) signature of constructor symbols and .^ a (finite) signature of function symbols. Thus, 
we are given an algebra of constructor terms TCif , ^). A rule is a pair (£, r), next written £ ^ r, where: 
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• £ = f{pi,--- ,pn) where f G ^ and pi G T(^, ^) for all / = 1, . . . ,«, 

• and reT(^U^,^) is a term such that any variable occuring in r also occurs in £. 

Definition 1. A program is a quadruplet f = (^,'^,^,(f ) such that S' is a. finite set of rules. We 
distinguish among ^ a main function symbol whose name is given by the program name f . F denotes 
the set of programs. 

The set of rules induces a rewriting relation — )-. The relation A is the transitive closure of -^, and — > 
is the reflexive and transitive closure of -^. Finally, we say that a term f is a normal form if there is no 

term u such that t ^- u. Given two terms t and u,t^u denotes the fact that t^u and m is a normal form. 

All along, when it is not explicitly mentioned, we suppose programs to be confluent, that is, the 
rewriting relation is confluent. 

The domain of the computed functions is the constructor term algebra T('^). The program f = 

(=^, '^, ^, S) computes a partial function [f ] : T{'WY — )■ T('^) defined as follows. For every mi , • • • , m„ G 

T('^), |{f](Mi, • • • ,Un) = V iff f (mi, • • • ,M„)->v and v is a constructor term. 

Definition 2 (Call-tree). Suppose we are given a program {3t^ ,'ig , ^, S). Let -^ be the relation 

{f,ti,...,t„) -^ {g,Ui,...,Um) 4^f{ti,...,t„) ^C[g{vi,...,Vni)]^C[g{ui,...,Uni)] 

where / and g are function symbols, C is a context and ?i ,...,?„, mi ,..., m^ are constructor terms. Given a 
function symbol / and constructor terms ti,...,t„, the relation -w defines a tree whose root is (/, fi , . . . , f„) 
and T]' is a daughter of 77 iff 77 ^^ 77'. The relation -~^+ is the transitive closure of ~-^. 

1.2 Interpretations of programs 

Given a signature Z, a Z- algebra on a domain A is a mapping (\—\) which associates to every «-ary symbol 
/ G r an «-ary function (\f\) : A" — )■ A. Such a Z-algebra can be extended to terms by: 

• dxD = 1a, that is the identity on A, for x G JT, 

• <\f{ti,. . . ,?m) D = comp((|/D, (|?i D, . . . , dfmD) where comp is the composition of functions. 

Given a term t with n variables, (|? D is a function A" — )• A. 

Definition 3. Given an ordered set (A,<) and a program (^,'^,^,(f), let us consider a {'tfUJ^)- 
algebra (\— D on A. It is said to: 

1. be strictly monotonic if for any symbol /, the function (|/D is a strictly monotonic function, that is 
if X; > x'i, then 

(\f\){xi,...,Xn) > <\f\){xi,...,X-,...,X„), 

2. be weakly monotonic if for any symbol /, the function (|/D is a weakly monotonic function, that 
is if X,- > xj, then 

(\f\){xi,...,X„) > <\f\){xi,...,X-,...,Xn), 

3. have the weak sub-term property if for any symbol /, the function (\f\) verifies (|/D(xi, . . . ,x„) > x,- 
with / G 1, . . . ,«, 

4. to be strictly compatible (with the rewriting relation) if for all rules £ ^- r, <\£\) > (\r\), 

5. to be weakly compatible if for all rules ^ — )■ r, l\£\) > i\r\j, 
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Definition 4. Given an ordered set (A,<) and a program {JZ' ,'tf , ^ , S") , a ("^ U ^) -algebra on A is 
said to be a strict interpretation whenever it verifies (1), (3), (4). It is a quasi-interpretation whenever it 
verifies (2), (3), (5). It is a monotone interpretation whenever it verifies (2) and (5). 

Clearly, a strict interpretation is a quasi-interpretation which itself is a monotone interpretation. When 
we want to speak arbitrarily of one of those concepts, we use the generic word "interpretation". We also 
use this terminology to speak about the function (\f\) given a symbol /. 

Finally, by default, A is chosen to be the set of real non negative numbers with its usual ordering. 
Moreover, we restrict the interpretations over the real numbers to be Max-Poly functions, that is functions 
obtained by finite compositions of the constant functions, maximum, addition and multiplication. Max- 
Poly denotes the set of these functions. 

Example 1. Equality on binary words in {0,1}*, boolean operations, membership in a list (built on 
cons, nil) are computed as follows. 

e = e -)• tt 

i(x) = i{y) -^ x = y with i E {0, 1} 

iW=J(3') ^ ffwithi/JG{0,l} 

or(tt,j) — )- tt 

or(ff,3') -^ y 

and(tt,3') — )• y 

and(ff,3;) -^ ff 

if ttthen j else z ^ y 

if ffthen y else z — t- z 

in(a,nil) — )• ff 

in{a,cons{b,l)) — t- if a = Zj then tt else in(a,/) 

Such a program has the strict interpretatioilj given by: 

^e^ = fltt^ = rf^ = ^nil^ = 1 

^i\){x) = x+ 1 with ie {0,1} 

(|consD(x,j) = x + y+l 

(\=^{x,y) = i\or\){x,y) = (\aiLd\){x,y) = x + y 

dif then else\){x,y,z) = x + y + z 

^in^{x,y) = {x + 2)xy 

Definition 5. The interpretation of a symbol / is said to be additive if it has the shape ^,oc,- + c. A 
program with an interpretation is said to be additive when its constructors are additive. 

1.3 Termination by Product Path Ordering 

Let us recall that the Product Path Ordering is a particular form of the Recursive Path Orderings, a 
class of simplification orderings (and so well-founded). Pioneers of this subject include Plaisted lIlTl . 
Dershowitz |5|, Kamin and Levy |[T2l . 



'To simplify thie verification of inequalities, interpretations are taken in [l,o°[. 
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Figure 1: Definition of ^ppo 
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Finally, let us mention that Krishnamoorthy and Narendran in l! T4l have proved that deciding whether 
a program terminates by Recursive Path Orderings is a NP-complete problem. 

Let ^x be a preorder on a signature £, called quasi-precedence or simply precedence. We write -<y. 
for the induced strict precedence and ^z for the induced equivalence relation on £. Usually, the context 
makes clear what £ is, and thus, we drop the subscript Z. 

Definition 6. Given an ordering ■< over terms T(r), the product extension of < over sequences, written 
<P, is defined as (^i , . . . , Sj^) -<p (f i , . . . , f^t) iff 

• for all i <k : Si ^ ?,• and, 

• there is some j <k such that 5, -< f,. 

where -< is the strict part of :<. 

Definition 7. Given a program {^,^, ^, £') and a precedence :<_^ over function symbols, the Product 
Path Ordering ^ppo is defined as the least ordering verifying rules given in Figured] 

1.4 Characterizations in the confluent case 

Tlieorem 1 (Bonfante, Cichon, Marion and Touzet 121). Functions computed by programs with additive 
strict interpretation are exactly Ptime functions. 

It is Theorem 4 in |[2l, first item. 

Tlieorem 2 (Bonfante, Marion and Moyen [3]). Functions computed by programs with 

• an additive quasi-interpretation and 

• a termination proof by PPO 
are exactly Ptime functions. 

The programs of this latter theorem are mentioned as RPOp^^^ -programs in fS^, Theorem 48. 
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2 Constructor preserving interpretations 

It is well known that the interpretations above can be used to bound both the length of the computations 
and the size of terms during the computations (see for instance JHIlll). Here we show that interpretations 
also cope with syntactic constraints. More precisely, programs with polynomial constructor preserving 
interpretations generalize cons-free programs 1 1 1 1. 

Let us consider a signature 'if, the signature of constructors in the sequel. S{'if) denotes the set of 
finite non-empty sets of terms in T('^). Let < denotes the sub-term relation on terms. On 5('^), we 
define <* as follows: m <* m' iff ^t £ m : 3t' ^ m' : t < t' . As an ordering on sets, for interpretations, we 
will use the inclusion relation. One may observe that m C m' =^ m <* m' . 

Definitions. Let us consider a monotone interpretation (|— D of a program (,^,^,^,(f ) over (5('^),C). 
We say that it preserves constructors if 

1. for any constructor symbol c G '^, (|cD(mi,. . . ,mk) = {c(?i,. ■■ ,tk) \ ti E m,-,/ = I,... ,k}. 

2. given a rule f{pi ,■■■ ,p„) — )■ r and a ground substitution a, for all u<r, 

<\a{u)\,<^a{f{pu--- ,Pn)))y^U^o{pi)l 

By extension, we say that a program is constructor preserving if it admits a constructor preserving mono- 
tone interpretation. 

The fact that a program preserves constructors fixes the definition of the interpretation over construc- 
tors. Moreover, (1) below gives a simple characterization of the interpretations of constructor terms. 

Proposition 1. For any constructor preserving interpretation (|— D, the following holds: 

1. for any ground constructor term t, (|f D = {f }, 

2. given a ground substitution o, for any constructor terms u<v, (\o{u) D <* (|cj(v) Y 

Proof. (1) is proved by induction on the structure of terms. (2) is by induction on the structure of v. 
Suppose V is a variable, if u<v, then u = v and the property holds trivially. Suppose v = c(vi , . . . , v^). 
The case m = v is as above. Otherwise, u < vj for some j < k. In that case, for all t € (|a(M) D, by 
induction, there is a Wj € (|<7(vy) D such that t < wj. Let us choose some w, G (|<7(v;) D for all / 7^ j. Then, 

t<c{wu.-.,wk) G ^a(c(vi,...,v^))^. D 

Proposition 2. Given a program (,^,^,^,(f) and a constructor preserving monotone interpreta- 
tion (|— D, for all constructor terms fi,...,f„ and all symbols f of arity n, if [/](?!,... ,f„) = t, then 

t£^f{ti,...,tn)l 

Proof. For a monotone interpretation, if m — )• v, then (\v\j C i\u\j. Suppose that /(?i, . . . ,t„)^t with t a 
constructor term, then, l\t\j C (|/(fi, . .. ,f„)[). But, due to Proposition [IK 1), d^D = {t}. The conclusion 

follows. n 

Definition 9. In the present context, an interpretation is said to be polynomially bounded if for any 
symbol /, for any sets mi,... ,m,„ the set (|/[)(mi, . . . ,m„) has a size polynomially bounded w.r.t. to the 
size of the m,'s. The size of a set m is defined to be \m\ = Y,tem kl- 

Proposition 3. Given a constructor preserving program, then, for all constructors c, the size of the set 

(|c D (m 1 , . . . , m„ ) is polynomially bounded w. r. t. the size of the m,- 's. 
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Proof. Let us write M = Y!l^i |m;|. Then, 

|^cD(mi,...,m„)| < Y, \c{t[,...,tn)\ 

i<n,tiEmi 

< ^ nxM+l since |f,| < |m;| < M 

i<n,tiEmi 

< M" X (n X M + 1 ) by a rough enumeration of 



the indices of the sum. 



D 



Example 2. Let us come back to Example [H it has a polynomially bounded constructor preserving 
monotone interpretation. Apart from the generic interpretation on constructors, we define: 

l\=){m,m') = \xn^{m,m') = {tt,ff} 
(|andD(m,m') = (|orD(m,m') = m'u{tt,ff} 
(|if then e\se\){mb,my,m^) = myUm^ 

It is clear that this interpretation is polynomially bounded. 

Actually, the notion of constructor preserving programs generalizes the notion of constructor-free 
programs as introduced by Jones (see for instance [11]). He has shown how constructor-free programs 
characterize Ptime and Logspace. We recall that a program is constructor-free whenever, for any rule 
f{pi, ■ ■ ■ ,Pn) — > r, for any subterm t <r, 

• if f is a constructor term, then t < f{p\ , • • • ,Pn), 

• otherwise, the root of t is not a constructor symbol. 

Proposition 4. Any constructor-free program {^ ,'io,-^ ,S) has a polynomially bounded constructor 
preserving monotone interpretation (|— 1). 

Proof. We use the generic definition for constructor symbols. For functions, let 

(|/D(mi,. .. ,m„) = {m I 3/ < «,? € m,- : M<?}. 

We have to prove a) that it is a monotone interpretation over S{^), b) that it preserves constructors 
and c) that it is polynomially bounded. 

Proof of c). Due to Proposition [TJ it is sufficient to verify the size condition on function symbols. Given 
some sets mi,. .. ,m„, we define m = {m | 3/ < n,? € m,- : m<?} and /T = | U"^jm,|. From the definition of 
the size of a set, for all j < n, |my| <K < Ya=\ \^i\- Let Sm,,...,m„ = {t \3i <n -.t G m,}. Then, 

n 
#5'mi,...,m„ < 52#m; < « X ^ (1) 

(=1 

where #m denotes the cardinality of a set m (recall that for any set m : #m < \m\\). For each term t, 
let Df = iu \ u<i t}. Since m = Ut^s Dt, \ni\ < y".pc IDA. It is clear that for all t, #Dt = \t\. 

Moreover, each u<t has a size smaller than t. Consequently, \Dt\ < |?p. Since for all terms t G 5^1,. ..,m„. 
\t\ < K, we. have \m\ < Y,tes„ „ ^^- Combining this latter equation with Equation [T] we can state that 
\m\<nxK^ <nx (^^^j |m,|)^ 
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Proof of b). Let us come back to the Definition [8] Tlie first item comes from our generic ciioice 
for the interpretations of constructor symbols. Concerning the second item, let us consider a rule 
f{pi,-" iPn) — 5- r, a ground substitution a and a subterm u<r. We prove actually a stronger fact 
than condition 2, namely: <\o{u) D C l\a{f{pi ,■■■ ,Pn)) D- By induction on u. 

If M is a variable or more generally a constructor term, since the program is constructor-free, u < pj 
for some j. Take t G (|a(M)D. Due to Proposition [Tl-(2), there is t' € I\g{pj)\) such that t <t'. Then, 
recalling the definition of (\fl t belongs to \f\){\o{pi)\j,. . . , ^a{p„) [)) = ^a(/(pi, • • • ,p„)) \). 

Otherwise, u = g{vi ,...,Vk) and, since the program is constructor-free, g is a function symbol. Take 
t € (|ct(m)D = (|g[)((|a(vi )[),..., (|(7(v;t)[))- Recall that ^ is a function symbol. Then, by definition of d^D, 
there is a 7 < ^ and a term t' G ^<y{vj) \) such that t < t'. By induction, t' € (|cj(/(pi , • ■ • ,Pn)) D- But then, 
by definition of ^fl t G ^f{pu- ■ ■ ,Pn) I 

Proof of a), Item (2) of Definition [3] is a direct consequence of the definition of the interpretation. Let 
us justify now (5). As seen above, for all rules f{p\,- ■ ■ ,Pn) — ^ r, ground substitutions a and subterms 
u^r, (\g{u) D C (\a{f{pi , • • • ,pn) 1). In particular, the result holds for r. D 

Do those kind of interpretations really go beyond constructor-freeness? Here is an example of a 
program which is not constructor-free, but with a constructor preserving interpretation. 

Example 3. Using the tally numbers 0, s, and lists, the function f builds the list of the first n — \ integers 
given the argument n. 

f(0) = nil 
f(s(«)) = cons(«,f («)) 

Such a program has a constructor preserving interpretation. Let 

<\f\){m) = {cons(ni,cons(«2,-'' (cons(?ij:,nil)) •••)) I 

3«i,. . . ,nk & m -.M j < k — I : n j = s(«y+i)} 
U{nil}. 

It is clear that this program is not constructor-free. But, there is a stronger difference: the function 
computed by this program cannot be computed by any constructor-free program. Indeed, recall that the 
output of functions computed by constructor-free programs are subterms of the inputs. Since this is not 
the case of f , the conclusion follows. 

Let us make one last observation about the example. Actually, the interpretation is polynomially 
bounded. Indeed, a list of the shape 

cons («!, cons (?22, ■ • ■ (cons (w^, nil)) • • • )) 

is fixed by the choice of «i and k. Since ^ < l«i j < \m\, there are at most \m\^ such lists, each of which 
has a polynomial size. 

Theorem 3. Predicates computed by programs with a polynomially bounded constructor preserving 
interpretation are exactly Ptime predicates. 

Proof. From Jones's result and Proposition HI it is clear that Ptime predicates can be computed by 
constructor preserving programs. 
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In the other direction, suppose we want to evaluate /(fi ,...,?„) where fi , . . . , f„ are some construc- 
tor terms. First, due to Propostion |2j one observes that the set of constructor terms i\f{ti,...,t„)\) = 
d/ [)( dfi [),..., (|f„ [) ) contains the normal form of /(fi ,...,?„) . Moreover, this set has a polynomial size 
w.r.t. the size of (|f,- [) 's. Due to Proposition[Tl (]?,• [) = {?,} and consequently | (]?,■ D | = |f; | . That is (|/(f i , . . . , f„) D 
has a polynomial size w.r.t. the size of inputs. 

As this is done by Jones, we use a call-by-value semantics with cache, that is: 

• we restrict substitutions to ground constructor substitutions, 

• each time a term g{ui , . . . , Um) is evaluated, it is put in a map {g,ui,..., Um) i-> [g] (mi , . . . , «,„)■ 
This map is called the cache. 

The key point to prove that computations can be done in polynomial time is to show that the cache has 
a polynomial size w.r.t. the size of the inputs. We begin to establish that for all constructor term m, such 
that f{ty ,..., tn)^C[g{ui ,..., Um)] : 

• there is a term t € (|/(?i,.. . ,?„)D U {?i,. .. ,?„} such that Uj^t, 

• fe(Ml , . . . , Mm) N* U{tl , . . . ,f„) ^ U {?i , . . .,tn}. 

One will have noticed that {?!,...,?„} = U'J^^(\ti\), so that (]/(fi ,...,?„)[) U {fi ,...,?„} = (\f{h ,-.-,tn)\) U^Li 
(\ti\). Second remark, terms like f{ti ,...,?„), g{ui , . . . , u^) as above correspond to nodes in the call tree 
with (/,?!,...,?„) -~^+ (g, Ml , . . . , M,„). So, we work by induction on -^+. 

Base case. Suppose that (/, ?i , . . . , f„) -^ {g,ui,..., u^)- In other words, there is a context C such that: 

f{ti ,...,?„)-> ^[^(vi , . . . ,v,„)]^C[g{ui ,..., u,„)]. 

By Lemma [T] below, m,- <t for some term t G (\f{ti,.. . ,f„)D U {fi, ...,?„} as required. 
For the second item, notice that g{vi , . . . , v^) ^ C[g{vi , . . . , v,„)] . Then, 

(\g{ui,...u„,)\) C (\g{vi,...,v,„)^ since g(vi,...,v,„)Ag(Mi,..., Mm) 

<* (|/(fi , . . . , f„) D U {fi , . . . , ?„} by Definition m second item 

Induction step. Otherwise, (/, fi , . . . , f„) ~^+ (g, mi , . . . , m^) -^ {h,wi,... , Wk)- By induction, we have 

^g{ui, ... ,u„,)\)<^f{ti, ... ,t„)\)[J{ti, ... ,tn} andioT alii <m, {ui} = (\ui\)<* (\f{tu ■■■ ,tn)\)U{ti, ... ,tn}- 
Consequently, 

^g{uu...,u„,)\,Uti(\ui\)<m{h,...,t„)\,U{h,...,t„}- (2) 

By Lemma[T] for all w,-, there is a term v € (|g(Mi , . . . , m,„) D U^j (|m; D. By Equation[2j there is a term 
f G d/(^i , . . . ,f«) ^ U {fi , . . . ,f„} such that Wi < t. 
For the second item, 

where the first relation is due to Definition [8l-(2). 

After this preliminary work, we are ready to bound the size of the cache. As a consequence of what 
precedes, the arguments of all the calls g{u\ ,..., Um) in the call tree are contained in the set 

S = {u\3t £ (\f{ti,. .. ,tn)^iJ{ti,.. . ,t„} : u<t}. 
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Since (|/(fi , . . . , f„) [) U {fi , . . . , f„} has a polynomial size, S itself has cardinality bounded by a polynomial, 
say P{\ti\,. ..,\t„\). As a consequence, since the m,'s are in 5, the cache has at most \^\ xP(|fi|,.. . , |f„|)^ 
entries, where D is a bound on the arity of symbols. Since each elements m, and each normal form of 
g{u\ , . . . , Mm) are subterms of (|/(?i , . . . , f„) [) U {fi , . . . , f„}, they have a polynomial size. Then, the cache 
itself has a polynomial size. D 

Lemma 1. Let {^ ,'^,,^,S') be a program with a polynomially bounded constructor preserving inter- 
pretation (|— 1). Suppose given a rewriting step f{ti ,... ,t„) —^w with ti,.. . ,t„ some constructor terms 

and v^w. If v— t-m with u a constructor term, then there is a term t € (\f{t\ , . . . , f„) D U"^ j (|f,- D such that 
u<t. 

Proof. Let f{pi,--- ,Pn) — > '' and a be such that f{ti,...,t„) = a{f{pi,--- ,Pn)) -^ O'(r) = w. There 
are two cases: if v < a(x) for some variable x G pj. Since the f,- are constructor terms, v is necessarily a 
constructor term, and consequently a normal form. So, v = u. As a matter of fact, v < <y{Pj) = tj. We 
conclude taking t = tj. 

Otherwise, v = ct(v') for some v' < r. Since v— s-m, we have (\u\) Q (\v\). By Proposition [Tl-(l), m G (|vD. 
Due to Definitiondl second item, there is t G (|/(fi , . • . , f„) D U"^i (|?,- D such that u<t. D 

3 Observation by non confluence 

3.1 Semantics 

We first have to define what we mean when we say that a function is computed by a non-confluent 
rewriting system. Computations lead to several normal forms, depending on the reductions applied. At 
first sight, we shall regard a non-confluent rewrite system as a non-deterministic algorithm. 

In this section, given a program, we do not suppose its underlying rewriting system to be confluent. 
By extension, we say that such programs are not confluent (even if they may be so). 

Example 4. A 3-SAT formula is given by a set of clauses, written V(xi ,X2,x^) where the x,- have either the 
shape -■(«() or e(?i,)|3 The «,'s which are the identifiers of the variables are written in binary, with unary 
constructors 0, 1 and the constant e. To simplify the program, we suppose all identifiers to have the same 
length, tt, f f represent the boolean values true and false. V serves for the disjunction. Since we focus on 
3-SAT formulae, we take it to be a ternary function. For instance the formula {x\ Vx2 Vxj) A (xi VxJ Vxj") 
is represented as: 

cons(V(e(0(l(£))),e(l(0(£))),^(l(l(£)))), 

cons(V(e(0(l(£))),^(l(0(£))),^(0(l(£)))),nil)). 

Recalling rules given in Example [H the following program computes the satisfiability of a formula. 
Let us suppose that i denotes the list of variables with the valuation "true", we have: 

ver(nil,^) -^ tt 

ver(cons(V(xi,X2,X3 ),!//'),£) — )■ and(or (or (eval(xi,^),eval(x2,£)),eval(x3,^)),ver ()//',£)) 

eval(-i(?i),^) —7- if ±n{n,i) then ffelse tt 

eva.l{e{n),i) — t- if ±n{n,i) then tt else ff 



e corresponds to a positive occurrence of a variable. It is introduced for a question of uniformity. 
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It is sufficient to compute the set of "true" variable. Tiiis is done by the rules: 

hyp (nil) = nil 

hyp(cons(V(a(xi),b(;c2),c(x3)),^)) -^ hyp(£) 

hyp(cons(V(a(xi),b(;c2),c(x3)),^)) -^ cons (^c,-, hyp (£)) 

hyp(cons(V(a(;ci),b(jC2),c(x3)),^)) — ^ cons(jc,, cons (xy, hyp (^))) 

hyp(cons(V(a(:ici),b(x2),c(x3 )),-£)) —?- cons(x,,cons(xy,cons(x/.,hyp(£)))) 

f(VA) -^ ver{Y,hypi¥)) 

with a,b,c G {~',e} and i j^ j ^k £ {1,2,3}. The main function is f. 

The rules involving hyp are not confluent, and correspond exactly to the non-deterministic choice. 
(By Newman's Lemma, the systems considered are not weakly confluent since they are terminating.) 

Such a program has an interpretation, given by: 

^K^) = ^eKx) = x+1 

(|VD(xi,X2,X3) = X1+X2+X3 + IO 

(\eva.l\){x,y) = (x+l)x3; + 3 

(\-vez\){x,y) = (x+l)x(3;+l) 

^hyp^x) = x+1 

l\f\lix) = ^ver(x,hyp(x))Kl 

Our notion of computation by a non-confluent system appears in Krentel's work ifTSl . in a different 
context. It seems appropriate and robust, as argued by Gradel and Gurevich [8|. 

We suppose given a linear order -< on symbols, this order can be extended to terms using the lexi- 
cographic ordering. We use the same notation -< for this order. Then, we say that a (partial) function 
(p : T(<^)'" -^ T(^) is computed by a program ( jr,<^,^,^) if for all fi , . . . ,f™ G T(^): 

(p{ti,...,t„) is defined <^(p(fi,...,f„) = max{v | /(?i,. .. ,?„)->v} 

In some case, we get the expected result: non-confluence corresponds exactly to non-determinism. 
Confluent programs with an interpretation compute Ptime, and the non-confluent ones compute NPtime. 

Theorem 4 (Bonfante, Cichon, Marion and Touzet |T|). Functions computed by non confluent programs 
with an additive polynomial interpretation are exactly NFtime functions; 

3.2 Non confluent programs with a polynomial quasi-interpretation 

The following result is more surprising. 

Theorem 5. Functions computed by non confluent programs that admit a quasi-interpretation and a 
PPO proof of termination are exactly P SPACE functions. 

The proof of the theorem essentially relies on the following example: 

Example 5. [Quantified Boolean Formula] Let us compute the problem of the Quantified Boolean For- 
mula. The principle of the algorithm is in two steps, the first one is top-down, the second one is bottom- 
up. In the first part, we span the computation to the leaves where we make an hypothesis on the value 
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of (some of) the variables. In the second part, coming back at the top, we compute the truth value of the 
formula and verify that the hypotheses chosen in the different branches are compatible between them. 

As above, we suppose that variables are represented by binary strings on constructors 0, 1,£. To 
them, we add the constructors cons, nil to build lists, T,^,A to decorate variables. Given a variable 
n, the decorations give the truth value of the variables. ♦(«) corresponds to an unchosen value, that 
is true or false, k{n) corresponds to false, and t(«) to true. The booleans are tt,ff and ± serves for 
trash. T and F are two (unary) constructors representing booleans within computations. To help the 
reader, we give an informal type to the key functions: *P corresponds to formulae, A to lists (of decorated 
variables) and B to truth values. Truth values are terms of the shape T(A) or F(A). Finally, V is the 
type of variables and B = {tt,ff}. The following rules correspond to the first step of the computation, 
f : »F ^^ B, ver : »P X A ^ B, not : B ^ B, or : B X B ^ B, vhyp :BxyxB^B, putiAx^xB^-A 
and hypList : *P — )■ A: 

f(<p) -^ ver(<p,hypList(<p)) 

ver(Var(x),/j) -^ T(put(/i,x,tt)) 

ver(Var(x),/i) -^ F(put(/i,x,ff)) 

ver(Or((pi,(p2),/2) -^ or(ver((pi,/z),ver((p2,/j)) 

ver(Not((p),/i) — > not(ver((p,/i)) 

ver (Exists (x,(jO),/j) — t- or(vhyp(ver((jO,/j),x,tt),vhyp(ver((jO,/j),x,ff)) 

where/jisa valuation of the variables. The rules ver(Var(x),/2) — )'T(put(/j,x,tt)) and ver(Var(x),/j) — ;■ 
F(put(/i,x,ff)) are the unique rules responsible of the non confluence of the program. This is the step 
where the value of variables is actually chosen. Concerning the valuations, they are written as lists 
cons (tv(?i), cons (• • • )) where the truth value tv of a variable is in {♦, T, A}. 

Suppose that x is a variable ocuring in Or (91,92)- One key feature is that in a computation of 
ver(Or((pi, (p2),h) — )• or(ver((pi,/j), ver((p2,/2)), the choice of the truth value of the variable x can be 
different in the two sub-computation ver{(pi,h) and ver{(p2,h). Then, the role of the bottom-up part of 
the computation is to verify that these choices are actually compatible. 

The two functions put and hypList are computed by: 

hypList(Var(x)) —> nil 
hypList(Or((pi,(p2)) — > append(hypList((pi),hypList((p2)) 

hypList(Not((p)) -^ hypList((p) 
hypList(Exists(x, 9)) -^ cons(4(x),hypList((p)) 
put(cons(^(«),Z),m,tt) — > if « = m then cons(T(«),Z) 

else cons(^(«),put(Z,m,tt)) 
put(cons(^(«), Z),m,ff) — > if « = m then cons(A(«),Z) 

else cons(^(«),put(Z,m,ff)) 

Then, the computation returns back. The top-down part of the computation returned a "tree" whose 
interior nodes are labeled with "or" and "not". At the leaves, we have T(Z) or F(Z) where Z stores the 
truth value of variables. The logical rules are: 
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not(F(x)) -^ T(x) or(T(x),T(3;)) -^ T(match(x,3;)) 

not(T(x)) -^ F{x) or(F(x),T(3;)) -^ T(match(x,3;)) 

or(T(x),F(3;)) -^ T(match(x,3;)) 

or(F(x),F(3;)) ^ F(match(x,3;)) 

where x and y correspond to the Ust of hypothesis. The function match takes two Usts and verify that 
they made compatible hypotheses on the truth value of variables. ♦(«) is compatible with both a(«) and 
T(«). But k{n) and j{n) are not compatible. 



mat ch(cons(x,Z), cons (x,Z')) 
mat ch(cons(T (x) ,1), cons (♦(x 
mat ch (cons ( A (x) , Z ) , cons ( ♦ (x 
mat ch (cons ( ♦ (x) , Z ) , cons ( T (x 
mat ch (cons ( ♦ (x) , Z ) , cons ( ▲ (x 
match(cons(T(x) , Z) , cons( A (x 
match(cons( A(x) , Z) , cons(T (x 



l,nil) 


-^ 


nil 


x,Z')) 


— ^ 


cons(x,match(Z,Z')) 




— ^ 


cons(T(x),match(Z,Z')) 




^ 


cons(A(x),match(Z,Z')) 




-^ 


cons(T(x),match(Z,Z')) 




-^ 


cons(A(x),match(Z,Z')) 




-^ 


± 




-^ 


_L 



The matching process runs only for lists of equal length and variables must be presented in the 
same order. This hypothesis is fulfilled for our program. The last verification corresponds to the Exists 
constructor. For the left branch of the or, the variable x is supposed to be true, for the second branch it 
is supposed to be false. This verification is performed by the vhyp function. 



vhyp{T{h),x,y) 

vhyp(F(/i),x,y) 

vhyp(cons(T(j),Z),x,tt) 

vhyp(cons(A(j),Z),x,tt) 

vhyp(cons(A(j),Z),x,ff) 

vhyp(cons(T(j),Z),x,ff) 



T{vhyp{h,x,y)) 

F(vhyp(/i,x,j)) 

if x = y then Z 

else cons(T(j),vhyp(Z,x,tt)) 

if x=y then X 

else cons(A(y),vhyp(Z,x,tt)) 

if x=y then Z 

else cons(A(j),vhyp(Z,x,ff)) 

if x=y then _L 

else cons(T(y),vhyp(Z,x,ff)) 



The rules for if then else , for = and for append are omitted. 

It is then routine to verify that this program is ordered by PPO. The order f >- ver >- vhyp >- put >- 
or >- not >- hypList >~ match ^ if >~ append )-= is compatible with the rules. 

To end the Example, we provide a quasi-intepretation. (|ver \){X,H) =X + H, (\f\) (<I>) = 2<t>, and for 
all other function symbols we take (]/ D {X\ , . . . ,X„) = max(Xi , . . . ,X„). For constructors, we take for all 
of them (lc\i{Xu...,Xn)= iLi X; + 1. 
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of Theorem^ Let us begin with the following proposition. 

Proposition 5. F.QI.PPO is closed by composition. That is iff,gi,. . .gu are computable with programs 
in F.QI.PPO, then, the function 

Xxi, . . . ,Xn.f{g\{xi, . . . ,Xn), . . . ,gk{x]_, . . . ,Xn)) 

is computable by a program in F.QI.PPO. 

Proof. One adds a new rule h{xi ,... ,x„) -^ f{g\ {x\,... .,x„),. . . ,gk{xi ,... ,x„)) with precedence h >- f 
and h >~ gj for all / < k. The rule is compatible with the interpretation: 

l\h\){xi,... ,Xn) = <\f{gl (JCI , . . . ,Xn),. . . ,gk{x\ , • • • ,X„)) ^. 

D 

The Example [5] shows that a PSPACE-complete problem can be solved in the considered class of 
programs. By composition of QBF with the reduction, since polynomial time functions can be computed 
in F.QI.PPO. n, any PSPACE predicate can be computed in F.QI.PPO. n. Let us recall now that computing 
bit ith of the output of a PSPACE function is itself computable in PSPACE. Since, building the list of 
the first integers below some polynomials can be computed in polynomial time, by composition, the 
conclusion follows. D 



3.3 Non confluent constructor preserving programs 

Theorem 6. Predicates computed by non confluent programs with a polynomially bounded constructor 
preserving interpretation are exactly the PTlME-computable predicates. 

This result is close to the one of Cook in H (Theorem 2). He gives a characterization of Ptime 
by means of auxiliary pushdown automata working in logspace, that is a Turing Machine working in 
logspace plus an extra (unbounded) stack. It is also the case that the result holds whether or not the 
auxiliary pushdown automata is deterministic. 

The proof follows the line of HI, we propose thus just a sketch of the proof. The key observa- 
tion is that arguments of recursive calls are sub-terms of the initial interpretation, a property that holds 
for confluent programs. As a consequence, following a call-by-value semantics, any arguments in sub- 
computations are some sub-terms of the initial interpretations. From that, it is possible to use memoiza- 
tion, see [10|. The original point is that we have to manage non-determinism. 

The proof of Proposition |2] holds for non confluent computations. So, normal forms of a term t are 
in (\t\). As we have seen in the proof of Theorem [3l this set has a polynomial size wrt the size of the 
inputs. In the non deterministic case, the cache is still a map, with the same keys, but the values of the 
map enumerate the list of normal forms. With the preceding observation, we can state that the map has 
still a polynomial size. 

Acknowledgement. I'd like to thank the anonymous referees for their precious help. Their sharp read- 
ing has been largely valuable to rewrite some part of the draft. 
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